<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>

<body>
  <script>
    let number = '男'
    const obj = {
      name: '罗飞',
      age: 18
    }

    Object.defineProperty(obj, "sex", {
      // value: '男',
      enumerable: true,//控制属性是否可以枚举,默认值都是false
      // writable: true,//控制属性是否可以修改,默认值都是false
      // configurable: true,//控制属性是否可以被删除,默认值都是false
      // // 当有人读取obj的age属性时,get函数就会被调用 返回值就是age的值
      get() {
        return number
      },
      // 有人修改sex属性时,set函数就会被调用 且会受到修改的具体值
      set(value) {
        number = value
        console.log('有人修改sex属性且值时', value);
      }
    })
    console.log(obj);
    number = '女'
    // 删除属性
    // delete obj.name
    // 遍历对象里的每一个属性
    console.log(obj);
    console.log(Object.keys(obj));
  </script>
</body>

</html>